草庐IT

mysql - 多个join的SQL查询

全部标签

ruby-on-rails - 查询多条记录时如何避免ActiveRecord::RecordNotFound异常

我有这个代码:Article.find([1,2,3])但数据库中只有记录1和2。我得到这个异常(exception):"ActiveRecord::RecordNotFound(Couldn'tfindallOfferswithIDs(1,2,3)(found2results,butwaslookingfor3))"有没有办法只获取现有记录而不获取异常? 最佳答案 Article.find_all_by_id([1,2,3])是要走的路! 关于ruby-on-rails-查询多条记录时

Ruby gem mysql2 安装错误

我在Windows7中安装了Ruby版本ruby​​1.9.2p0(2010-08-18)[i386-mingw32]。和gem版本1.3.7当我尝试安装mysqlgem时,它显示Failedtobuildgemnativeextension错误,这是为什么?我的mysql版本是5.1.36(WampServer)E:\RubyApps\test_app2>geminstallmysql2Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingmysql2:ERROR:Failedtobuildgemnat

ruby - 如何更新 Ruby on Rails 3 中的多个列?

出于好奇,有没有办法这样说...user.update_column(:field1,true)user.update_column(:field2,true)...在RubyonRails中在一行中?据我所知,update_columns方法不存在... 最佳答案 您可以按如下方式使用update_all:User.where(:id=>user.id).update_all({:field1=>true,:field2=>true})这将生成以下更新语句(mysql):UPDATEusersSETfield1=1,field2=

ruby-on-rails - 如何在 Ruby on Rails 中连接到 MySQL?

我真的是RubyonRails的新手。我读过thistutorial这听起来很简单。但是我如何连接到我的数据库(MySQL)或者Rails使用什么?在php中我会使用...mysql_connect("...","...","...");mysql_select_db("...");我已经搜索了谷歌,找不到任何有用的提示。 最佳答案 查看配置文件config/database.yml您需要在那里设置您的配置。以下是生产环境的示例:production:adapter:mysql2encoding:utf8database:examp

ruby - 具有可选查询参数的 Sinatra

我想创建一个带有可选查询参数的SinatraAPI路由。我可以按如下方式添加查询参数%r{^/mysql/data/(?)/start_time=(?\w*)/?}但是上面route对应的route是像"/mysql/data/:name/start_time=:start_time"我需要查询参数作为可选参数并以URL格式声明。例如:/mysql/data/:name?start_time=:start_time&end_time=:end_time在Sinatra中有什么方法可以做到这一点吗? 最佳答案 引自Sinatra文档:

ruby - 如何转义 Ruby 中的字符串以防止 SQL 注入(inject)? (无导轨)

我只是想知道我们如何在Ruby中转义SQL查询(字符串)以防止SQL注入(inject)。请注意我没有使用Rails框架。谢谢。 最佳答案 如果可能,请使用RubyDBI模块,而不是尝试引用您的字符串,而是使用参数化的准备查询,如下所示:dbh=DBI.connect("DBI:Mysql:test:localhost","testuser","testpass")sth=dbh.prepare("INSERTINTOpeople(id,name,height)VALUES(?,?,?)")File.open("people.txt

ruby-on-rails - 将多个字符串传递给 ruby​​ starts_with?

我有这个代码ifself.name.starts_with?('Bronze')||self.name.starts_with?('Silver')||self.name.starts_with?('Gold')有没有一种方法可以一次传递所有这些字符串而不是大量的OR,因为我可能必须对此进行扩展? 最佳答案 String#start_with?接受任意数量的参数。您不需要使用||。'Silvermedal'.start_with?('Bronze','Silver','Gold')#=>true'Hellomedal'.start_

ruby - 使用 Nokogiri HTML Builder 创建具有多个根节点的片段

我有一个关于Nokogiri的简单问题。我想让Nokogiri::HTML::Builder制作以下形式的HTML片段:#Somestuffinhere#Someotherstuffinhere尝试做的时候:@builder=Nokogiri::HTML::Builder.new(:encoding=>'UTF-8')do|doc|doc.div{doc.p"firsttest"}doc.div{doc.p"secondtest"}end@builder.to_html我得到一个错误:Documenthasalreadyarootnode,我部分理解了。我知道我没有将整个内容包装到标签

sql - 如何使用 Sequel 运行原始 SQL 查询

我还不清楚使用Sequel运行原始SQL查询的正确方法。目前我正在尝试这个:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")do|row|@zonename=rowend我怎样才能将查询作为原始SQL运行,然后像平常一样访问结果?if@zonename.name="UK" 最佳答案 请注意,而不是:DB.fetch("SELECT*FROMzoneWHEREdialcode='#{@dialcode}'LIMIT1")你应该这样做:DB.fetch("SELE

ruby-on-rails - Rails 3 Join——只选择某些列

下面是评论和用户之间的关系。每个评论都有一个用户,所以我在下面的代码中构建了一个连接。我想知道如何构建此代码以仅在连接中包含特定列。我不需要所有的用户信息。只是名字。任何建议。当前代码:@comments=Comment.where(:study_id=>@study.id).joins(:user) 最佳答案 你可以使用这样的东西:@comments=Comment.joins(:user).select("comments.*,users.first_name").where(study_id:@study.id)